66/!0/60 

liHiHIi 



TN THV TTNTTED STATES PATENT AND TRADEMARK OFFICE 

In re Patent Application of: Bohr- Winn Shih et al. 

Title: SIMULATED CIRCUIT NODE EQUALIZING AND MONITORING 

Attorney Docket No.: 303 .5 13US 1 

PATENT APPLICATION TRANSMITTAL 



"*VO 

o i 



BOX PATENT APPLICATION 

Assistant Commissioner for Patents 
Washington, D.C. 20231 

We are transmitting herewith the following attached items and information (as indicated with an "X"): 

X Utility Patent Application under 37 CFR § 1 .53(b) comprising: 

X Specification ( JSL pgs, including claims numbered through ^ and a _L page Abstract). 

X Formal Drawing(s) ( _i. sheets). 

X Signed Declaration ( _i_pgs). 
; X Check in the amount of Sil, 732.00 to pay the filing fee. 
^ Assignment of the invention to Micron Technology. Tnc. ( J_ pgs) and Recordation Form Cover Sheet. 
Xi Check in the amount of $40.00 to pay the Assignment recording fee. 

X I Return postcard. 



The filing fee has been calculated below as fo' 


lows: 




No. Filed 


No. Extra 


Rate 


Fee 


mn AL CLAIMS 


35-20 = 


15 


xl8 = 


$270.00 


'independent claims 


12-3 = 


9 


x78 = 


$702.00 


|j ] MULTIPLE DEPENDENT CLAIMS PRESENTED 


$0.00 


"SksiC FEE 


$760.00 


TOTAL 


$1,732.00 



Please charge any additional required fees or credit overpayment to Deposit Account No. 19-0743. 



SCHWEGMAN T.TTNnRFT^G, WOFSSNF.R & KT JITR PA. 
P.O. Box 2938, Minneapolis, MN 55402 (612-373-6900) 

Customer Number 21186 



Atty: Thonias W. LefferT 
Reg. No. 40,697 



"Express Mail" mailing label number: F.T, 7.5461800411?; Date of Deposit: September 2, 1999 

I hereby certify that this paper or fee is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 37 
CFR 1 . 1 0 on the date indicated above and is addressed to the Assistant Commissioner for Patents, Box Patent Application, Washington, D.C. 2023 1 . 



By:. 



Chris Hammond 



Signature: . 



SIMULATED CIRCUIT NODE INITIALIZING AND MONITORING 



Technical Field of the Tnvention 
The present invention relates generally to electronic circuitry simulation 
programs and in particular to program modules that control initial conditions and 
5 provide error detection for simulated circuit nodes. 

Copyright Notice/Permission 
A portion of the disclosure of this patent document contains material which 
is subject to copyright protection. The copyright owner has no objection to the 
10 facsimile reproduction by anyone of the patent document or the patent disclosure as 

it appears in the Patent and Trademark Office patent file or records, but otherwise 
reserves all copyright rights whatsoever. The following notice applies to the 
software and data as described below and in the drawings hereto: Copyright © 
1999, Micron Technology, Incorporated, All Rights Reserved. 

15 

Rankgronnd of the Invention 
Electronics have become part of ahnost every aspect of modem life, from 
television sets to toasters. As technology progresses, electronic circuits become 
increasingly complex. Designing a circuit with hundreds or even thousands of 

20 individual electronic components has become a great challenge for circuit designers. 

The challenge becomes even greater when many iterations of prototypes are 
required to test out the circuits and prove their viability. As the number of 
components multiply, building the actual circuit and modifying it becomes an 
expensive and time consuming proposition. 

25 To overcome the problems associated with working with real components, 

circuit designers turned to computers to aid them with their designs. By using a 
computer, designers could create "virtual" circuits. This enabled designers to create, 
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modify and test circuits without actually building the circuit with real components. 
Hardware Description Languages (HDL) were developed to aid designers in creating 
the virtual circuits. HDL programs allow designers to choose from a standardized 
set of instructions while designing their circuits on computers. Many different HDL 

5 programs have been written, each with varying capabilities. Among these HDL 

programs is Verilog HDL which is widely used and is considered an industry 
standard among circuit designers. 

Verilog HDL uses the computer to simulate complex circuit designs with 
various inputs and outputs. It uses "modules" or lines of code representing a desired 

10 function as building blocks to create the simulation. The designer builds simulated 

circuitry by simply selecting and connecting the desired modules. Individual 
"nodes" or electrical connection points of the circuit can be analyzed while changing 
input variables to the circuit. The designer can even initialize nodes of the circuitry 
to various logic values before the simulation is started. Currently, however, this 

1 5 initial node parameter is not stabilized and will "float" or change to an unknown 

logic value during the simulation run. The designer has no way of knowing when or 
if the initial condition of the node has changed. If this is crucial to the design, it 
presents a serious, time consinning issue to surmount. 

One method of overcoming this problem is to write a separate simulation 

20 program and use Verilog' s Programming Language Interface (PLI) to export the 

desired node value to the separate simulation program. However, this method 
requires that a specific co-simulation program be written by a programmer for each 
Verilog simulation. This is both costly and time consuming and slows down the 
design cycle. Accordingly, what is needed is a simulation initiaUzation and 

25 monitoring solution that is both quick and cost effective to use in circuit design, 

especially when using Verilog HDL. 

Sliimmary of the Invention 
The present invention provides a method and apparatus for initializing and 
30 monitoring a simulated circuit node in a simulation system. An initial condition 
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(IC) behavior module is provided in a hardware definition language simulation 
system which operates in two phases. In the first phase, the IC module sets an 
initial logic condition onto a user-selected node which is to be monitored. The IC 
module will release the initial condition and then test the node value to determine if 
5 the simulation system is able to resolve the node. Altematively, the IC module may 

release the node if a user-defined IC time period passes. In the second phase, the IC 
module monitors the node and reports an error detection message if the simulated 
node value becomes imacceptable. 

These and other embodiments, aspects, advantages and features of the 
10 present invention v^U be set forth in part in the description which follows, and in 

part will become apparent to those skilled in the art by reference to the following 
description of the invention and referenced drawings or by practice of the invention. 

rj The aspects, advantages and features of the invention are reaUzed and attained by 

means of the instrumentalities, procedures and combinations particularly pointed out 

03 15 in the appended claims. 

1;^ Brief Description of the Drawings 

n Figure 1 is a diagram depicting an environment of one embodiment of the 

' 4 present invention. 

20 Figure 2 is a block diagram illustrating how the present invention is selected 

.5 for use in one embodiment. 

" Figure 3 is a block diagram of one embodiment of the present invention. 

Figure 4 is a functional flow diagram of the embodiment shown in Fig. 3. 
Figure 5 is a block diagram of another embodiment of the present invention. 
25 Figure 6 is an expanded view of the inputs of the embodiment of Fig. 5. 

Figure 7 is an expanded view of the outputs of the embodiment of Fig. 5. 
Figure 8 is a functional flow diagram of the embodiment of Fig. 5. 
Figure 9 is a depiction of examples of the media on which the present 
invention can reside. 
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Figure 10 is another embodiment of the present invention in a computer 

system. 

Detailed Descriptinn of the Kmhodiments 
5 In the following detailed description of the preferred embodiments, 

reference is made to the accompanying drawings which form a part hereof, and in 
which is shown by way of illustration specific preferred embodiments in which the 
inventions may be practiced. These embodiments are described in sufficient detail 
to enable those skilled in the art to practice the invention, and it is to be imderstood 

1 0 that other embodiments may be utilized and that logical or software changes may be 

made without departing from the scope of the present invention. The following 
detailed description is, therefore, not to be taken in a limiting sense, and the scope of 
the present invention is defined only by the appended claims. 

The present invention is used in conjunction with a computer software 

1 5 program and, thus, requires some understanding of how the computer program 

operates. In order to provide a clearer understanding, a description of how the 
computer software program is used relevant to the invention is provided, followed 
by detailed descriptions of the present invention's embodiments. 

Verilog HDL is a hardware description language for designing and 

20 documenting digital logic systems. The language is used to create programs that 

simulate the interaction between components. The programs are composed of one 
or more independently developed modules that are not combined until the program 
is linked. A single module can contain one or more routines which are sections of a 
program that perform a particular task or tasks. Generally, it is the program user 

25 who decides which modules will be Hnked to perform an executable program. 

Modules are usually chosen from a list in a way that when linked they will perform 
a desired behavior. With programs such as Verilog HDL, the modules can be linked 
to form complex logic systems with compUcated behavioral characteristics. The 
program user can define intricate input logic levels and create detailed electronic 
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components that alter the logic levels to produce an output logic level with the 
user's designed specifications. 

Often it is desirable to be able to monitor a logic level within the circuitry 
itself and not just at the final output. The user may also require that an initial logic 

5 level, also known as an initial condition, be set on certain nodes within the system to 

be simulated before executing the program. In order to accomplish these tasks, a 
separate simulation program is usually written using the Programming Language 
Interface (PLI) fimction of the Verilog HDL, The PLI consists of an interface 
mechanism, a set of routines to interact with the simulation environment and a set of 

1 0 routines to access the Verilog HDL internal data structures, providing dynamic 

interaction with the electronic circuitry simulation and the data structures. The 
disadvantages of PLI is that a separate co-simulation program is required and often 
times the interaction of the PLI program causes the Verilog HDL program to slow 
down to allow the data to be transferred back and forth between the two programs. 

1 5 This Umits any "real time" analysis of the electronic circuitry. 

The current invention is a behavior module that performs initiaUzing and 
monitoring and manipulating logic level fimctions. Because it is a module, it is 
selectable from within a hardware design language program, such as Verilog HDL, 
and eliminates the need and constraints of a PLI co-simulation program. This initial 

20 condition (IC) module provides a means to initiahze logic nodes (force an initial 

logic condition) to a desired logic level and to release the node if certain conditions 
are met. The release of the node means that the simulation program is free to 
change the logic value of the node if simulation warrants a change in the logic value. 
Before release, the logic value of the node is forced. 

25 The IC module will release the node if certain conditions are met. One 

condition is the passage of time. The IC module may be programmed to hold the 
initial condition of the node for a user-defined period of time. After expiration of 
that user-defined time period, the node is released. Another release of the node by 
the IC module is when the simulation system is able to resolve the logic level of the 

30 node. Resolving the node means that the inputs to the node are known and therefore 
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the logic value of the node can be determined through simulation by the simulation 
program. Thus, the IC module will release the node if the node can be resolved. 
Those skilled in the art will recognize other conditions upon which the node may be 
released. 

5 The IC module can also monitor the node after it is released. If the node has 

been released, and the logic value of the node later becomes unknown, the IC 
module flags this as an error condition which may be the result of a logic design 
error. When monitoring the node, one skilled in the art will appreciate that an error 
condition from the IC module can be used to trigger error messages, halt simulation 

1 0 programs, trigger other parts of the simulated circuitry or viewed on a display 

device. 

The convenience of having the ability to select a module to perform these 
functions also removes the timing constraints imposed by PLI co-simulation 
programs. The module allows for "real time" monitoring and analysis of the node 

15 voltage during the simulation program execution. The time and expense of writing a 

separate co-simulation program for the PLI is completely eliminated. A single user 
can insert the module where needed as they construct the simulated circuit, saving 
both time and money. 

Figure 1 is an example of an environment in which the present invention 

20 operates. A computer system 10 contains a hardware definition language 

program 20 which is stored on the computer system 10 hard drive in this example. 
Within the HDL program, is an executable simulation program 30 and a resource set 
of available modules 40. A user selects which modules to use from the available 
modules 40 and these modules become part of the executable simulation 

25 program 30. The selected modules 50 then interact with simulation program 

instructions 60 to form the executable simulation program 30. 

Figure 2 shows an enlarged list of selected modules 50 and an enlarged list 
of available modules 40. Normally, not all of the available modules 40 are executed 
as part of the executable simulation program 30. The present invention behavior 

30 module is selectable from the list of available modules 40. In the example of 
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Figure 2, the present invention module is called an initial condition module or an IC 
module 110. To use the IC module 110, the user selects it from the list of available 
modules 40 and then it becomes part of the selected modules 50 which are used 
during the execution of the simulation program 30. Referring back to Figure 1, 

5 when the simulation program 30 is executed, a simulated circuit 70 with the user's 

design characteristics is created. Generally, the simulated circuit 70 will have many 
connections or nodes such as node 80. This simulated circuit 70 is then tested by 
varying parameters such as the initial condition value of node 80. 

In one embodiment shown in Figure 3, the IC module 110 contains routines 

10 to allow an initial node value input 150, a forced node value output 160, a simulated 

node value input 180 and an error indication output 190. The initial node value 
input 150 is either a user definable variable or a variable determined from within the 
executable simulation program or external to the executable simulation program. 
The initial node value input 150 is the initial logic value that the node is set to at the 

15 start of the simulation program. The initial logic condition may be a logic one, logic 

zero or high-impedance. The IC module 110 forces the logic level 160 for the node 
80 if conditions warrant the forcing. If the forced initial condition is still warranted 
(as described above), the simulated circuit 170 is then simulated based upon the 
forced value 160 for that node. 

20 The forced node value 160 is then released to allow the simulated node 

value 180 to be input to the IC module 1 10. The simulated node value is monitored 
by the IC module monitoring routine during the simulation program execution and 
after the release of the node. If the node value changes to an unknown value, the IC 
module reports an error detection via the error indication output 190. To one skilled 

25 in the art, it can be appreciated that the error detection can be triggered by other 

events besides a node value that is unknown. For example, the error condition can 
be triggered by the node value remaining unchanged for a length of time. The 
modules are linkable, and it is within the scope of the claimed invention to have 
several modules interconnected or one module linked to multiple nodes. 
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Figure 4 shows a data flow chart for the embodiment show in Figure 3. The 
operation of the IC module 110 can be viewed in two phases. In the first phase of 
operation, an initial node value (logic level) is set at 300 for a selected node. The 
logic level for the selected node value is held at that value until it is released by the 
5 IC module. As the simulation begins, the value is forced to the initial condition at 

310 to hold the logic value on the node. As the simulation progresses to the next 
time step, the node is then released at 3 15 to allow the simulation program to 
attempt to resolve the node value. The value of the node is then tested at 3 16 to 
determine if the simulation software was successful in resolving the node value. If 

10 the node value is indeterminable or unknown at 3 16, the IC module will force the 

initial condition 310 once again via 305 of Figure 4, If the simulation software is 
successful in resolving the value of the node, then IC module enters a second phase 
of operation to monitor the node value. In the alternative, if a user-defined IC 
manipulation time period expires, the IC module will enter the second phase. 

15 In the second phase of operation, IC module 110 can continue to monitor the 

node value 320 until the end of simulation or imtil it is halted by a user-defined time 
limit, or by some other mechanism known to those skilled in the art. The node 
value is continually tested at 330 to determine if the node value changes to an 
unknown, indeterminable or otherwise unacceptable logic state. If the value is 

20 valid, the IC module 110 continues to monitor the node value at 320 via 325. If the 

value is unacceptable, an indication of this condition is made at 340 via 335 and the 
simulation continues as control is passed via 325 to continue to monitor the node at 
320 after the xmacceptable condition is noted at 340. 

Another embodiment is shown in Figures 5-7. The IC module 205, as shown 

25 in Figure 5, includes inputs 200, outputs 210, node settings 206 and node data 207 

interfaces. The inputs 200 contain additional routines to allow an IC manipulation 
time period 220, a hold node constant command 230, an IC error detection 
period 235 and an IC simulation run time 236 as shown in Figure 6. Additional 
routines are also included in outputs 210 to allow an error indication 190, a real time 

Attorney Docket No. 303,513US1 8 Client Ref. No, 98-0034 



node value output 240 and an end of simulation node value output 250 as shown in 
Figure 7. 

The IC manipulation time period 220 is set to force the simulation node 80 
to contain the desired information within the desired time interval of simulation 

5 program execution. The hold node constant command 230 is used to pass the node 

settings 206 to the simulation circuitry 170 such that the node value remains 
constant when the release conditions are met in IC module 205. The hold node 
constant command 230 allows a user, an internal link or an external link to instruct 
the module to force the node value to a constant value for the duration of the 

1 0 simulation program execution or until a release condition such as at a user-defined 

IC manipulation period 220 or if resolved. 

To one skilled in the art, it can be appreciated that the IC manipulation time 
input 220 can be used to control the length of time that the node is held to a constant 
value. The real time node value output 240 is the node value as monitored via the 

1 5 node value input 207 and is output for the duration of the error detection period 235. 

The IC error detection period 235 is used by the module to monitor the node logic 
value during the simulation program execution. To one skilled in the art, it can be 
appreciated that this input value can be used to limit the duration of the monitoring 
activities of the module even before the simulation program has fully executed. 

20 The IC simulation run time input 236 is used by the module to determine the 

start and finish of the IC simulation program execution. This time is used to 
determine the end of simulation node value output 250 based on a user-defined 
period of time executing the simulation program. 

The module outputs 210 are displayable by any number of means including 

25 CRT displays, printouts and any device used to convey information. The module 

outputs are also usable as inputs to other modules to provide further control of the 
simulation program or to trigger other events, internal or external to the simulation 
program. The module inputs 200 are input by any number of means including 
keyboards, touch screens and any device used to input information. The module 
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inputs are also linkable to outputs of other modules to provide further control of the 
simulation program or to trigger other events. 

Figure 8 shows a flow chart for the embodiment shown in Figures 5-7. In 
this embodiment, two general phases are shown. In the first phase, an initial node 

5 value, an IC manipulation time, a hold node constant command, an error detection 

period and an IC simulation run time are obtained 400 and then a simulated circuit 
node value for the node to be controlled/monitored is forced to equal to the initial 
node value 410, As the simulation progresses to the next time step, the IC 
module 205 then releases the node value at 415 to allow the simulation software of 

10 the simulated circuit 170 to attempt to resolve the value of the node, A check is then 

performed at 420 to determine if the node value has been resolved and is therefore 
valid. If the simulation software has been unable to resolve the node value to an 
acceptable or vahd logic condition (e.g.: logic one, zero or high-impedance), the IC 
module 205 will once again force the initial condition on the node at 410. The 

15 simulation will then continue by once again releasing the node at 415 and testing 

again at 420. This loop will continue until the node resolves to a valid value. In the 
alternative, if a user-defined IC manipulation time period 220 passes, control will 
pass to the second phase to monitor the node value at 440. Those skilled in the art 
will readily recognize that what is a vahd condition and what is invalid is 

20 determined by the needs of the user using the simulation program. In some 

applications, an invahd or unknown logic state may be acceptable. 

If the node resolves to a valid logic state or if the user-defined IC 
manipulation time period 220 has passed, then phase two of the operation of the IC 
module 205 begins. The second phase shown in Figure 8 is the monitoring phase 

25 which begins at 440. At this point, the simulated circuit node is monitored 440 to 

catch any logic state change. If there is any change of the node value detected, the 
node value is tested to see if it is acceptable at 450. If the node value is acceptable 
(decision branch 455), the value of the node is output to the user at 460. If the node 
value is unacceptable (decision branch 465), an error indication is output 470. 

30 Afterwards, a check is performed at 480 to see if the error detection time period 235 
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is ended. If the IC error detection period 235 has not expired (decision branch 486), 
the control flow returns to monitoring the node at 440 and the cycle is repeated If 
the user-defined error detection time period 235 has ended (decision branch 485), 
simulation advances to decision block 490 via path 485. If the IC simulation run 

5 time 236 is ended in 490, the final value of the node is output via 491 to the user at 

499 and the IC simulation is ended at 500, otherwise the real time value can be 
output via 492 to the user at 495 and the check loop is repeated via 496 until the end 
of IC simulation run time 236 is complete. Those skilled in the art will readily 
recognize that what is a valid/acceptable condition and what is invalid/unacceptable 

10 condition is determined by the needs of the user using the simulation program. In 

some apphcations, an unknown logic state may be recognized as acceptable. 

In another embodiment of the invention shown in Figure 9, the module is 
part of a list of instructions found on computer readable media such as diskettes, 
hard drives or random access memory. In yet another embodiment of the invention 

1 5 shown in Figure 10, the module is part of a computer system used to design 

simulated electronic circuitry. 

In summary, the present invention is a module that is easily selected from 
within the hardware definition language program. It has inputs for setting various 
parameters used to control and monitor circuit nodes from within a simulation 

20 program. The module's outputs provide both control of the circuit node voltage and 

also information that is displayable or is used to provide further control of other 
modules. 

An advantage of the present invention is that the module is part of the 
simulation program and not a separate co-simulation program. This allows faster 

25 simulation and eliminates the need to write another program. Both of these aspects 

save time and money. Another advantage is the ease of use afforded the user due to 
the fact that the module is selectable as part of the simulation program and can be 
incorporated "on the fly" as the circuit design is being developed. This ensures 
greater accuracy during troubleshooting and also ensures that the designer is the one 

30 who chooses the correct monitoring points. 
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Other incorporations and uses of the module will be apparent to those skilled 
in the art. It is to be understood that the above description is intended to be 
illustrative and not restrictive. Many other embodiments will be apparent to those 
of skill in the art upon reviewing the above description. The scope of the invention 
5 should, therefore, be determined with reference to the appended claims, along with 

the full scope of equivalents to which such claims are entitled. 
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What is claimed is: 



1 . A method of simulating a node, comprising: 

forcing an initial logic state on the node; 
5 releasing the node if a predetermined condition is met and creating therefrom 

a released node; 

monitoring the released node; and 

providing an indication when the released node is in a preselected condition. 

10 2. The method of claim 1 , wherein forcing the initial logic state includes 

forcing to a logic zero, logic one or high-impedance. 

3 . The method of claim 1 , wherein releasing the node further comprises 
determining that the condition is met after passage of a predetermined amount of 

15 time. 

4. The method of claim 3, wherein releasing the node further comprises 
determining that the condition is met when the node has been resolved 

20 5 . The method of claim 1 , wherein providing an indication includes indicating 

when the released node is in an unknown logic state. 

6. The method of claim 1, further comprising providing an error indication 
when the released node is a preselected condition. 



25 



7. The method of claim 3, further comprising selecting a user-defined time 
period for the predetermined amount of time. 
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8. A method of initializing and monitoring a simulated circuit node, 
comprising: 

obtaining an initial node condition for a node; 

forcing the node to the initial node condition; 
5 simulating a circuit containing the node; 

testing the node for a valid condition; 

monitoring the node; and 

providing an indication when the node is in an undesirable condition. 

10 9. The method of claim 8, wherein the initial node condition is forced again if 

the testing results in the node resolving to an unknown logic value. 

10. The method of claim 9, wherein the initial node condition is forced and 
simulation is repeated until the node resolves to a valid logic value, 

15 

1 1 . The method of claim 10, wherein monitoring only occurs after the node 
resolves to a valid logic value. 

12. The method of claim 8, further comprising outputting the condition of the 
20 simulated node. 

13. The method of claim 8, further comprising obtaining a simulation run time. 

14. The method of claim 13, further comprising outputting a final node 
25 condition when the simulation run time is completed. 
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15. A computer-readable medium having computer-executable instructions 
comprising: 

forcing an initial logic state on the node; 

releasing the node if a predetermined condition is met and creating therefrom 
5 a released node; 

monitoring the released node; and 

providing an indication when the released node is in a preselected condition, 

1 6. The medium of claim 15, having further computer-executable instructions 
10 for forcing the initial logic state to a logic zero, logic one or high-impedance. 

17. The medium of claim 15, having further computer-executable instructions 
for determining that the condition is met after passage of a predetermined amount of 
time. 

15 

18. The medium of claim 15, having further computer-executable instructions 
for determining that the condition is met when the node has been resolved 



19. The mediimi of claim 8, having further computer-executable instructions for 
20 indicating when the released node is in an unknown logic state. 



20. A simulation module for initiaUzing and monitoring a simulated circuit 
node, comprising: 

an input means for inputting an initial node condition; 
25 a conveying means for conveying the initial node condition to a simulated 

node; 

release means for releasing the node upon satisfaction of a condition; 

a monitoring means for monitoring the simulated node for a node condition; 

and 
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an output means for outputting an indication when the node condition is in 
an undesirable state. 

21 . The module of claim 20, further comprising an output means for outputting 
5 the node condition. 

22. The module of claim 20, further comprising an input means for inputting a 
simulation run time. 

10 23 . The module of claim 22, further comprising an output means for outputting a 

final node condition at completion of the simulation run time, 

24. A computerized system for initializing and monitoring a simulated circuit 
node, the system comprising: 

15 a circuit simulation tool; 

a first input module inputting an initial node condition; 

a conveying module conveying the initial node condition to a simulated 

node; 

a release module releasing the initial condition; 
20 a monitoring module monitoring the simulated node for a node condition; 

a first output module outputting an indication when the node condition is in 
an undesirable state; 

a second input module inputting a simulation run time; and 
a second output module outputting a final node condition at completion of 
25 the simulation run time. 

25. An HDL initial condition module comprising a means for maintaining a 
logic level of a simulated circuit node until a release condition is met. 
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26. The module of claim 25 wherein the release condition is when the node can 
be resolved to a known logic state. 

27. The module of claim 25 wherein the logic level is a value defined by an 
5 HDL executable simulation program. 

28. An HDL initial condition module having an initial condition release means 
and a simulated circuit node error detection means. 

10 29. An HDL initial condition module comprising means for maintaining a logic 

level of a simulated circuit node for a predetermined period of time, means for 
releasing an initial condition, and wherein the predetermined period of time is a 
simulation run time defined by an HDL simulation executable program. 

1 5 30. The module of claim 29, wherein the predetermined period of time is a user- 

defined period of time. 

31. An HDL simulated circuit device, comprising: 
a first HDL module comprising: 
20 a first input submodule inputting a first initial node condition; 

a first conveyance submodule conveying the first initial node 
condition to a first simulated node; 

a first monitor submodule monitoring the first simulated node for a 
first node condition; and 
25 a first output submodule outputting a first indication when the first 

node condition is in an undesirable state; 
a second HDL module comprising: 

a second input submodule inputting a second initial node condition; 
a second conveyance submodule conveying the second initial node 
30 condition to a second simulated node; 
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a release submodule releasing the node on a predetermined condition; 
a second monitor submodule monitoring the second simulated node 
for a second node condition; and 

a second output submodule outputting a second indication when the 
5 second node condition is in an undesirable state; and 

wherein the first conveyance submodule additionally conveys the first initial 
node condition to the second input submodule. 



32. An HDL simulated circuit device, comprising: 
1 0 a first HDL module comprising: 

a first input; 

a first conveyance; 

a first node condition output 
a second HDL module comprising: 
15 a second input; 

a second conveyance; 
a third HDL module comprising: 

a release condition; 
wherein the first node condition output means outputs the first node 
20 condition to the second input means if the release condition is valid. 

33. An HDL design tool, comprising: 
a circuit simulation device; and 

a plurality of selectable modules capable of being linked to the circuit 
25 simulation device, wherein at least one of the selectable modules executes the 

following conraiands: 

inputting an initial node condition; 
conveying the initial node condition to a simulated node; 
releasing the node if a condition is met; 
30 monitoring the simulated node for a node condition; and 
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an output means for outputting an indication when the node condition 
is in an undesirable state. 

34. A simulation method, comprising: 
5 phase one, including; 

forcing an initial logic zero, logic one or high-impedance on a node; 
releasing the node; 

testing to see if the node has been resolved; 
if the node has been resolved, continue to phase two 
10 if the node has not been resolved, continuing in phase one 

phase two, including; 

monitoring the node value; 
testing the node value; 

indicating an error if an unacceptable condition appears on the node; 

15 and, 

continuing in phase two until simulation completion. 

35. The method of claim 34, wherein simulation completion is a user defined 
time period. 

20 



Attorney Docket No, 303.513US1 



19 



Client Ref. No. 98-0034 



Abstract of the Disclosure 
An initial condition (IC) behavior module is described for use in a hardware 
definition language simulation system which operates in two phases. In the first 
phase, the IC module sets an initial logic condition onto a user-selected node which 
5 is to be monitored. The IC module will release the initial condition and then test the 

node value to determine if the simulation system is able to resolve the node. 
Alternatively, the IC module may release the node if a user-defined IC time period 
passes. In the second phase, the IC module monitors the node and reports an error 
message if the simulated node value becomes unacceptable. 
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DECLARATION FOR PATENT APPLICATION 

As a below named inventor I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; 

I believe I am an original, first an joint inventor of the subject matter which is claimed and for which a 
patent is sought on the invention entitled: 

SIMULATED CIRCUIT NODE INITULIZING AND MONITORING . 

The specification of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above-identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose all information which is material to the patentability of this apphcation 
in accordance with Title 37, Code of Federal Regulations, ^ 1.56 (see page 3 attached hereto). 

I hereby claim foreign priority benefits under Title 35, United States Code, ^119/365 of any foreign 
application(s) for patent or inventor's certificate listed below and have also identified below any foreign application 
for patent or inventor's certificate having a filing date before that of the application on the basis of which priority is 
claimed: 

No such claim for priority is being made at this time. 

I hereby claim the benefit under 35 U.S.C. § 1 19(e) of any United States provisional application(s) listed 

below: 

No such claim for priority is being made at this time* 

I hereby claim the benefit under Title 35, United States Code, § 120/365 of any United States and PCT 
international application(s) listed below and, insofar as the subject matter of each of the claims of this application is 
not disclosed in the prior United States application in the manner provided by the fu-st paragraph of Title 35, United 
States Code, § 112, 1 acknowledge the duty to disclose material information as defined in Title 37, Code of Federal 
Regulations, § 1. 56(a) which became available between the filing date of the prior application and the national or 
PCT international filing date of this application. 

No such claim for priority is being made at this time. 
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that willful false statements and the like so made are punishable by fme or imprisonment, or both, under Section 
1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 
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Citizenship: United States of America Residence: Meridian, ID 

Post Office Address: 4423 E. Trafalger Ct. 

Meridian, ID 83642 
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Citizenship: United States of America Residence: Boise, ID 
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John Stuart Mullin, Sr. 
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§ 1.56 Duty to disclose information material to patentability. 

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the 
most effective patent examination occurs when, at the time an application is being examined, the Office is aware of 
and evaluates the teachings of all information material to patentability. Each individual associated with the filing and 
prosecution of a patent application has a duty of candor and good faith in deahng with the Office, which includes a 
duty to disclose to the Office all information known to that individual to be material to patentabihty as defined in this 
section. The duty to disclose information exists with respect to each pending claim until the claim is canceled or 
withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a 
claim that is canceled or withdrawn ft-om consideration need not be submitted if the information is not material to the 
patentability of any claim remaining under consideration in the application. There is no duty to submit information 
which is not material to the patentability of any existing claim. The duty to disclose all information known to be 
material to patentability is deemed to be satisfied if all information known to be material to patentability of any claim 
issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§ 1.97(b)-(d) and 
L98. However, no patent will be granted on an application in connection with which fraud on the Office was 

< practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office 
encourages applicants to carefully examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) the closest information over which individuals associated with the filing or prosecution of a 
patent application believe any pending claim patentably defines, to make sure that any material 
information contained therein is disclosed to the Office. 

(b) Under this section, information is material to patentability when it is not cumulative to information 
already of record or being made of record in the application, and 

(1) it establishes, by itself or in combination with other information, a prima facie case of 
unpatentability of a claim; or 

(2) it refiites, or is inconsistent with, a position the applicant takes in: 

(i) opposing an argument of unpatentability relied on by the Office, or 

(ii) asserting an argument of patentability. 

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is 
unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its 
broadest reasonable construction consistent with the specification, and before any consideration is given to evidence 
which may be submitted in an attempt to establish a contrary conclusion of patentability. 

(c) Individuals associated with the fiUng or prosecution of a patent application within the meaning of this 
section are: 

(1) Each inventor named in the application: 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the 
application and who is associated with the inventor, with the assignee or with anyone to whom 
there is an obligation to assign the application. 



(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing 
information to the attorney, agent, or inventor. 



